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CLAIM AMENDMENTS 

This listing of claims will replace all prior versions and listings of claims in the 
application. 
JListing of Claims 

1 . (Currently Amended) A method of searching a LPM (longest prefix match) to perform 
a single search in a database which holds a plurality of prefixes in groups and defines an initial 
search area made up of a plurality of ranges, comprising steps of: 

(a) performing a round of binary LPM searches by executing a plurality of search 
instances in parallel, each search instance searching in a different range of the initial 
search area; 

(b) in response to the last round of binary LPM searches, defining a new search area by 
eliminating, from further searches, one or more ranges; 

(c) performing a further round of binary LPM searches to perform the single search by 
executing the plurality of search instances in parallel, each search instance searching in a 
different sub-range of the new search area; 

(d) in response to the last round of binary LPM searches, defining further a new search 
area by eliminating, from further searches, one or more sub-ranges; 

(e) storing a longest match found in a round of binary LPM searches, and 

(f) if necessary, repeating steps (c) to (e) to further narrow the new search area until 
either one of the search instances finds a longest matching prefix or all the search areas 
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have been searched, in which case the last longest match becomes the longest matching 

\ prefix. 

2. (Original) The method according to claim 1 wherein the database is a routing table in 
a packet forwarding device and the plurality of prefixes are logically sorted in groups in an 

■ ascending order of their lengths, 

f 

<• 

3, (Original) The method according to claim 2, wherein step (a) is performed with search 

%■ 

: instances starting at predetermined locations within their respective ranges, the predetermined 

f • 

locations being at about the midpoint in the lowest range and being progressively shifted toward 

i the respective low ends within higher ranges. 

^' 
i 

f 

'i 4. (Original) The method according to claim 3, wherein the step of defining the new 

j search area comprises a step of: 

eliminating those ranges or sub-ranges which contain prefixes shorter than the longest 
match of the last round of the binary LPM searches. 

- 

•t 

i 
't 

} 5. (Original) The method according to claim 4, wherein the step of performing a further 

\ round of binary LPM searches comprises further steps of: 

in response to the last round of binary LPM searches, determining locations within the 
new search area at which the search instances start the next round of binary LPM searches, 

s 

i< 
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< 

directing the search instances which searched the eliminated ranges or sub-ranges in the 
last round to begin the further round of binary LPM searches at the determined locations. 

6. (Original) The method according to claim 5 T wherein when determining the locations 
( within the new search area, the order of the search instances are maintained. 

7. (Original) The method according to claim 3, wherein the step of executing a plurality 

I of search instances in parallel, comprises a step of: 

i 

!: issuing parallel memory accesses to several memory banks at once to access in parallel a 

\ \ plurality of bins in either the initial or new search area. 

I 
} 

8. (Original) The method according to claim 3, wherein the step of executing a plurality 
of search instances in parallel, comprises a step of: 

issuing several memory accesses to a single memory bank to access in parallel a plurality 
of bins in either the initial or new search area such that the latencies of these memory accesses 
overlap. 

9. (Original) The method according to claim 3, wherein the step of executing a plurality 
of search instances in parallel comprises a step of: 

issuing a plurality of prefetch instructions and accessing in parallel a plurality of 
locations in either the initial or new search area. 
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10. (Original) The method according to claim 6, wherein the step of executing a plurality 
of search instances in parallel, comprises a step of: 

issuing parallel memory accesses to several memory banks at once to access in parallel a 
plurality of bins in either the initial or new search area. 

1 L (Original) The method according to claim 6, wherein the step of executing a plurality 
of search instances in parallel, comprises a step of: 

issuing several memory accesses to a single memory bank to access in parallel a plurality 
of bins in either the initial or new search area such that the latencies of these memory accesses 
overlap. 

12. (Original) The method according to claim 6, wherein the step of executing a plurality 
of search instances in parallel comprises a step of: 

issuing a plurality of prefetch instructions and accessing in parallel a plurality of 
locations in either the initial or new search area. 

13. (Currently Amended) A method of conducting a LPM (longest prefix match) search 
to perform a single search in a packet forwarding device having a routing table containing a 
plurality of prefixes stored in a plurality of bins, each of which may contain one or more prefixes 
of the same length and markers, all the bins being logically sorted in an ascending order of their 
lengths and defining an initial search area which are divided into a plurality of contiguous 



PAGE 10/18 ' RCVD AT 6/512007 5:04:25 PM [Eastern Daylight Time] ■ SVR:USPT0-EFXRMI16 ■ DNIS:2738300 ' CSID:703 5199802 * DURATION (mm-ss):05-U 



JUN-05-2007 17:06 



KRPMER & PMADO> P.C. 



703 5199802 P 



! Application No: 10/731,125 

; Attorney's Docket No: ALC3103 

ranges, within each of which range the bins are logically preordered for access in each round of 

: binary LPM searches, comprising steps of: 

(a) performing a first round of binary LPM searches by executing a plurality of search 
instances in parallel, each search instance searching in its respective range, starting at the 

i 

:j bin preordered for the first access within the range; 

(b) continuing further rounds of binary LPM searches by executing a plurality of search 
I instances in parallel, each search instance searching in its respective range, starting at a 
; successively preordered bin or at one directed by a marker; 

(c) if a match or marker is found by a search instance in each round of binary LPM 
;> searches, Storing it in a memory as a last tongest match; 

i (d) defining a new search area by eliminating, from further searches, one or more ranges 

? containing bins of prefix lengths shorter than the last longest match; 

•i 
i, 

; (e) performing a further round of binary LPM searche s to perform the single search by 

executing the plurality of search instances in parallel, each search instance searching in a 

j different sub-ranges of the new search area, and 

< 

;! (f) if necessary, repeating steps (b) to (e) to further narrow the new search area until 

I 

either one of the search instances finds a longest matching prefix or all the search areas 
have been searched, in which case the last longest match becomes the longest matching 

\ prefix. 

* 

I 

•>. 
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14. (Original) The method according to claim 13, wherein step (e) comprises further 
steps of: 

in response to the last round of searches, determining bins within the new search area at 
which the search instances start the next round of searches, and 

directing one or more search instances which searched in ranges or sub-ranges of prefixes 
shorter than the last longest match during the last round to begin the further round of searches 
starting at the determined bins of the new search area which contains the last longest match. 

15. (Original) The method according to claim 14, wherein the number of bins in each 
ranges are predetermined and the bins ordered first for access in each range are located at about 
the midpoint of the lowest range and at locations progressively offset toward the low end of each 
of the higher ranges. 

16. (Original) The method according to claim 1 5, wherein the step of executing a 
plurality of search instances in parallel, comprises a step of: 

issuing parallel memory accesses to several memory banks at once to access in parallel a 
plurality of bins in either the initial or new search area. 

17. (Original) The method according to claim 15, wherein the step of executing a 
plurality of search instances in parallel, comprises a step of; 
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issuing several memory accesses to a single memory bank to access in parallel a plurality 

of bins in either the initial or new search area such that the latencies of these memory accesses 

overlap. 

1 8. (Original) The method according to claim 1 5, wherein the step of executing a 
plurality of search instances in parallel, comprises a step of: 

issuing a plurality of prefetch instructions and accessing in parallel a plurality of bins in 
either the initial or new search area. 

19. (Currently Amended) An apparatus for conducting LPM (longest prefix match) 
searches to perform a single search in a packet forwarding device, comprising: 

a routing table containing a plurality of prefixes to be searched and defining an initial 
search area; 

a plurality of search instances for performing a plurality of rounds of parallel binary LPM 
searches in their respectively assigned portions of the initial search area; 

an analyzing module for defining a new search area within the initial search area in 
response to the results of a last round of binary LPM searches; 

a memory for storing a longest match found in a round of binary LPM searches; 

a controller for assigning the search instances to perform successive rounds of binary 
LPM searches to perform the single search within mutually different portions of the new search 
area until one of the search instances finds the longest matching prefix. 



PAGE 13/18* RCVD AT 6/512007 5:04:25 PM [Eastern Daylight Time] 1 SVR:USPT0-EFXRF-1/16 * DNIS:2738300 * CSID:703 5199802 * DURATION (mm-ss):05-H 



JUN-05-2007 17:07 



KRAMER 8, AM ADO i P.C. 



703 5199802 P 



Application No: 10/731,125 
Attorney's Docket No: ALC 3 1 03 

20. (Original) The apparatus according to claim 19, wherein the routing table comprises 
a plurality of bins, each of which contains one or more prefixes of a same length and may al$o 
contain at least one marker, the bins being logically sorted in order of their prefix lengths and the 
initial search area being divided into a plurality of contiguous ranges, each range containing a 
predetermined number of bins. 

21 . (Original) The apparatus according to claim 20, wherein within each range, bins are 
preordered for access by the search instances for each round of searches, if no match or marker is 
found. 

22. (Original) The apparatus according to claim 21 , wherein the ranges contain sufficient 
number of bins to accommodate a desired number of prefixes in compliance with IPv6. 

23. (Original) The apparatus according to claim 22, wherein the size of the ranges are 
predetermined so that the worst case memory accesses are evened out across all the ranges. 

24. (Original) The apparatus according to claim 23, wherein the number of bins in each 
ranges are predetermined and bins ordered first for access in each range are located at about the 
midpoint in the lowest range and at locations progressively offset toward the low end of each of 
the higher ranges. 
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25. (Original) The apparatus according to claim 19, wherein the controller further 
comprises a memory access mechanism for issuing parallel memory accesses to several memory 
banks at once to access in parallel a plurality of bins in either the initial or new search area, 

26. (Original) The apparatus according to claim 1 9, wherein the controller further 
comprises a memory access mechanism for issuing several memory accesses to a single memory 
bank to access in parallel a plurality of bins in either the initial or new search area such that the 
latencies of these memory accesses overlap. 

27. (Original) The apparatus according to claim 19, wherein the controller further 
comprises a memory access mechanism for issuing a plurality of prefetch instructions to access 
in parallel a plurality of bins in either the initial or new search area. 

28. (Original) The apparatus according to claim 24, wherein the controller further 
comprises a memory access mechanism for issuing parallel memory accesses to several memory 
banks at once to access in parallel a plurality of bins in either the initial or new search area. 

29. (Original) The apparatus according to claim 24, wherein the controller further 
comprises a memory access mechanism for issuing several memory accesses to a single memory 
bank to access in parallel a plurality of bins in either the initial or new search area such that the 
latencies of these memory accesses overlap, 
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30. (Original) The apparatus according to claim 24, wherein the controller further 

comprises a memory access mechanism for issuing a plurality of prefetch instructions to access 

in parallel a plurality of bins in either the initial or new search area. 
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